package com.crm.miaohe.mapper;

import com.crm.miaohe.model.TblNavigation;
import com.crm.miaohe.model.TblNavigationExample;
import java.util.List;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.ResultMap;
import org.apache.ibatis.annotations.Select;
import org.apache.ibatis.annotations.SelectKey;
import org.apache.ibatis.annotations.Update;

@Mapper
public interface TblNavigationMapper {
    long countByExample(TblNavigationExample example);

    int deleteByExample(TblNavigationExample example);

    @Delete({
        "delete from tbl_navigation",
        "where id = #{id,jdbcType=BIGINT}"
    })
    int deleteByPrimaryKey(Long id);

    @Insert({
        "insert into tbl_navigation (title, url, ",
        "create_time, create_user, ",
        "update_time, update_user, ",
        "version)",
        "values (#{title,jdbcType=VARCHAR}, #{url,jdbcType=VARCHAR}, ",
        "#{createTime,jdbcType=TIMESTAMP}, #{createUser,jdbcType=VARCHAR}, ",
        "#{updateTime,jdbcType=TIMESTAMP}, #{updateUser,jdbcType=VARCHAR}, ",
        "#{version,jdbcType=BIGINT})"
    })
    @SelectKey(statement="SELECT LAST_INSERT_ID()", keyProperty="id", before=false, resultType=Long.class)
    int insert(TblNavigation record);

    int insertSelective(TblNavigation record);

    List<TblNavigation> selectByExample(TblNavigationExample example);

    @Select({
        "select",
        "id, title, url, create_time, create_user, update_time, update_user, version",
        "from tbl_navigation",
        "where id = #{id,jdbcType=BIGINT}"
    })
    @ResultMap("com.crm.miaohe.mapper.TblNavigationMapper.BaseResultMap")
    TblNavigation selectByPrimaryKey(Long id);

    int updateByExampleSelective(@Param("record") TblNavigation record, @Param("example") TblNavigationExample example);

    int updateByExample(@Param("record") TblNavigation record, @Param("example") TblNavigationExample example);

    int updateByPrimaryKeySelective(TblNavigation record);

    @Update({
        "update tbl_navigation",
        "set title = #{title,jdbcType=VARCHAR},",
          "url = #{url,jdbcType=VARCHAR},",
          "create_time = #{createTime,jdbcType=TIMESTAMP},",
          "create_user = #{createUser,jdbcType=VARCHAR},",
          "update_time = #{updateTime,jdbcType=TIMESTAMP},",
          "update_user = #{updateUser,jdbcType=VARCHAR},",
          "version = #{version,jdbcType=BIGINT}",
        "where id = #{id,jdbcType=BIGINT}"
    })
    int updateByPrimaryKey(TblNavigation record);
}